博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Omi实战-QQ附近用户列表Web页
阅读量:6035 次
发布时间:2019-06-20

本文共 5022 字,大约阅读时间需要 16 分钟。

写在前面

Omi很适合大型复杂的Web页面开发,例如一些Web在线工具的开发。但是制作这种简单的QQ附近用户列表Web页,也不会有大炮哄蚊子的感觉。

项目开始之前,实现选择一个脚手架。这个项目用的就是作为其项目脚手架。主要基于 Gulp + Webpack + Babel + BrowserSync 进行开发和部署。(ps:目前脚手架先上github弄下来,pasturn和Aresn正在开发omi-cli,不久就要发布了)

Gulp用来串联整个流程,Webpack + Babel让你可以写ES6和打包,BrowserSync用来帮你刷浏览器,不用F5了。

这里需要注意的是,BrowserSync会启动localhost:3000导致你的AJAX请求跨域而无法拿到数据。

所以,要使用Fiddler并配置Extention:

目录

目录结构也是和一样。

组件全放在component目录,公共的工具库放在common,其他资源文件放在asset里。

命令

开发

npm run dev复制代码

发布

npm run dist复制代码

开始写码

万事具备,开始写码。先写组件:

import Omi from 'omi'class UserList extends Omi.Component {    constructor(data) {        super(data)    }    install() {        this.data.uin_info || (this.data.uin_info = [])        this.data.uin_info.forEach(user => {            this.prepareData(user)        })    }    prepareData(user){        user.desc_d = user.desc.split(" ")[0]        user.desc_t = user.desc.split(" ")[1]        user.isBoy = user.sex === "男"        user.qlogo = user.url.replace("http://", location.protocol + "//").replace(/&/g, "&")        if (user.profession_desc) {            user.hasProfession_desc = true        }    }    appendUsers (users) {        users.uin_info && users.uin_info.forEach(user =>{            this.prepareData(user)            this.data.uin_info.push(user)        })        this.update()    }    sendGift(uin, nick, qlogo) {        //送礼物并关闭webview,此处省略        //..        //..    }    render() {        return `
{
{#uin_info}}
{
{
{nick}}}
{
{#isBoy}}
{ {age}} {
{/isBoy}} {
{^isBoy}}
{ {age}} {
{/isBoy}} {
{#hasProfession_desc}}
{ {profession_desc}} {
{/hasProfession_desc}}
{
{
{intro}}}
{
{desc_d}} · {
{desc_t}}
{
{/uin_info}}
加载中...
` } style() { return `.qlogo { overflow: hidden; width: 70px; height: 70px; -webkit-border-radius: 50%; border-radius: 50%; position: absolute; top: 10px; left: 12px;}........这里省略大量............distance_info { position: absolute; top: 15px; right: 9px; color: #7B7B84; font-size: 10px;} ` }}export default UserList复制代码

组件里面有5个方法:

  • constructor 组件的构造函数,生命周期的一部分,其实在super上面和super调用下面可以对data做一些处理。super之上不能拿到this
  • install 组件的初始化安装,生命周期的一部分,这里也可以拿到用户传进的data进行处理
  • prepareData 对数据进行一些处理来满足模板的渲染
  • appendUsers 新增数据,用来处理用户向下滚动的load more 的行为的时候调用
  • sendGift 送礼物,点击每一项的时候会有送礼物的行为,业务相关,可以无视..

其他两个方法的render和style用来生成组件的HTML和局部CSS,不再叙述。

render里面使用了模板引擎;
如果使用omi.lite.js版本(不包含模板引擎)的话,你也可以使用ES6 map去遍历数据生成HTML,或者重写 Omi.template去使用任意你喜欢的模板引擎,非常灵活方便。

这里友情提醒一下,如果使用webstorm的话,可以把js version设置成JSX Harmony或者ECMAScript 6,这样才是写ES6+的姿势。

下面来看index.js:

import Root from './config.js'import Omi from 'omi'import UserList from '../component/user_list/index.js'Omi.makeHTML('UserList', UserList)class Main extends Omi.Component {    constructor(data) {        super(data)    }    installed() {        window.onscroll = () => this.loadMore()        this.requestData(data => this.list.appendUsers(data))    }    loadMore() {        const body = document.body,            html = document.documentElement,            height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight),            vp_height = window.innerHeight        if (height - document.body.scrollTop - vp_height < 200) {            this.requestData(data => this.list.appendUsers(data))        }    }    requestData(callback) {        if (Root.isDev) {            require.ensure([], ()=> {                callback(require('./mock_data.js').default)            })        }else{            //ajax 请求数据,这里省略        }    }    render() {        return `    
` }}Omi.render(new Main(),'body')复制代码

通过Omi.makeHTML('UserList', UserList)这句代码,UserList变成了可以嵌套至render方法中的标签。如:

render() {        return `    
` }复制代码

下面这行代码,是监听滚动,快滚动到底部的时候在loadMore里面会去请求。

window.onscroll = () => this.loadMore()复制代码

通过height - document.body.scrollTop - vp_height < 200判断用户快要滚动底部,滚动到底部有个加载更多的行为,即:

if (height - document.body.scrollTop - vp_height < 200) {    this.requestData(data => this.list.appendUsers(data))}复制代码

requestData是去服务器请求分页的数据,请求成功,会去调用this.list.appendUsers进行数据的添加。

慢着?this.list哪里来的?appendUsers又是哪里定义的方法?且看下面:

复制代码

上面标记的name,让你可以直接通过this.list访问到UserList对象的实例,所以也就可以调用它的appendUsers方法!

再来看下数据模拟:

if (Root.isDev) {        require.ensure([], ()=> {            callback(require('./mock_data.js').default)        })    }复制代码

这里在dev环境下是mock数据,使用了require.ensure,这样当你npm run dist的时候,mock的数据就不会被打包进js里了!!

最后

好了,就这么多,Omi让代码真心方便简洁~~~

相关地址

招募计划

  • Omi的Github地址
  • 如果想体验一下Omi框架,请
  • 如果想使用Omi框架,请阅读
  • 如果想一起开发完善Omi框架,有更好的解决方案或者思路,请阅读
  • 关于上面的两类文档,如果你想获得更佳的阅读体验,可以访问
  • 如果你懒得搭建项目脚手架,可以试试
  • 如果你有Omi相关的问题可以
  • 如果想更加方便的交流关于Omi的一切可以加入QQ的Omi交流群(256426170)

转载地址:http://uodhx.baihongyu.com/

你可能感兴趣的文章
ccf 地铁修建
查看>>
解决table边框圆角无效
查看>>
EasyUI的tree展开所有的节点或者根据特殊的条件控制展示指定的节点
查看>>
PHP多次调用Mysql存储过程报错解决办法
查看>>
PHP实例——获取文件的绝对路径
查看>>
567. Permutation in String字符串的排列(效率待提高)
查看>>
环绕型布局
查看>>
CSS中font-style的属性有Italic oblique,它们俩的区别是什么呢?
查看>>
gitlab结构分析
查看>>
c++类构造函数初始化列表
查看>>
实验二+138+牟平
查看>>
Eval
查看>>
WebForm 使用点滴。。。。
查看>>
fiddler还是浏览器的问题
查看>>
springmvc全局异常处理
查看>>
Unity 执行命令行
查看>>
游戏爱好调查问卷结果
查看>>
[C++11]shared_ptr效率比较
查看>>
防止 NSTimer retain 作为 target 的 self
查看>>
tabhost使用
查看>>